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DETAILED ACTION 

1 . This action is in response to tine amendment filed 8/6/2009. 

2. Claims 1-45 remain pending in this application and have been considered below. 

Response to Amendment 

3. The objection to the specification for introducing new matter is maintained in view 
of applicant's amendment. 

4. The rejections to claims 1 -45 under 35 U.S.A first and second paragraph are 

maintained in view of applicant's amendment. 

5. The undersigned attorney has been contacted by the examiner on 1 0/14/2009 
and discussed the allowable subject matter by examiner's proposed amendment based 
on the cited references and also a new reference. On 10/22/2009, the undersigned 
indicated to the examiner to issue an office action because he is still reviewing the prior 
arts. 

Response to Arguments 

6. Applicant's arguments filed 8/6/2009 have been fully considered but they are not 
deemed persuasive. 

Applicant argues: 

1 . "without loading the third set of instructions into the execution unit and without loading 
the second set of instructions into the execution unit when loading the first set of 
instruction" is supported by the original specification pages 11-13 of the Remarks. 
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2. Szoke fails to teach "replacing the unresolved reference with an address of a third set 
of instructions without loading the third set of instructions into the execution unit and 
without loading the second set of instructions into the execution unit when loading the 
first set of instructions" recited in claim 1 . 

3. Szoke fails to teach "loading an executable object module, wherein the loading 
includes replacing an unresolved reference with a reference to a system module without 
loading instructions of the system module" recited in claim 7. 

4. Szoke fails to teach "a loader unit to find an executable object module in a storage 
unit and present the executable object module to an execution unit, where the loader 
unit is configured to replace the unresolved reference with a reference to a system 
module without loading instructions of the system module with the system module 
separate from the execution object module and the loader unit is separate from the 
executable object module" recited claims 17 and 21 . 

5. Szoke fails to teach "a loader unit to present an executable object module for 
execution, wherein the loader unit is configured to replace a symbolic reference with an 
address to a system module to link the executable object module and the separately 
compiled object module such that instructions of the loader unit are separately compiled 
object module" recited in claim 26. 

6. Szoke fails to teach "replacing, in an executable object module, symbolic references 
with addresses to a loader subroutine without instructions of the loader subroutine in the 
executable object module" recited in claims 12 and 41 . 
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Examiner's response: 

1 . The phrase "according to embodiment of the invention, when an application program 
is launched, the computer system 100 loads only the object module that is currently 
needed for program execution" cited by the application does not indicate or inherently 
teach "loading a first set of instructions... without loading the third set of instructions into 
the execution unit and without loading the second set of instructions into the execution 
unit." This expression only indicates the computer system loads all the object modules 
that are needed by the program execution. According to this expression, the second 
and third sets of instructions are the object modules that are not needed for program 
execution and therefore never get loaded into the execution unit for execution. Thus, 
the limitations of claim 1 are contradicting themselves because claim 1 indicates that 
second and third sets of instructions are not needed (i.e. without loading) but then it also 
indicates that the second and third sets of instructions are executed (i.e. loaded for 
execution). The applicant also cited two paragraphs at page 6 of the specification to 
support his argument but these two paragraph do not indicate that the loading a first set 
of instructions... without loading the second and third sets of instructions. Applicant is 
respectfully advised that limitation from the specification cannot be brought into the 
claim. For examination purpose, examiner assumes that the second and third sets of 
instructions are loaded for execution. 

2. Szoke teaches "branch statement 122 causes a branch to linkage program..." (see 
col. 4:3-7). As explained above, the third set of instructions must be loaded by the 
computer system for program execution. 
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3. As explained above, the third set of instructions is loaded for execution because it is 
needed. Therefore, Szoke teaches the limitations of claim 7. 

4. Szoke teaches at least in FIG. 1 that P1 1 , P12, and linkage program 130 are loaded. 
Although they are part of load module 100 but they are separated programs. 

5. As explained above, FIG. 1 of Szoke teaches that P11, PI 2, and linkage program 
130 are loaded and separated. 

6. As explained above, the second and third sets of instructions are loaded, separate, 
and executed. 



Specification 

7. The amendment filed 3/1 7/2008 is objected to under 35 U.S.C. 1 32(a) because it 
introduces new matter into the disclosure. 35 U.S.C. 132(a) states that no amendment 
shall introduce new matter into the disclosure of the invention. The added material 
which is not supported by the original disclosure is as follows: "...without loading the 
third set of instructions into the execution unit and without loading the second set of 
instructions into the execution unit when loading the first set of instruction" recited in 
claim 1 or similar concept recited in other independent claims are not originally 
disclosed in the specification. 

Applicant is required to cancel the new matter in the reply to this Office Action. 



Claim Rejections - 35 USC §112 

8. The following is a quotation of the first paragraph of 35 U.S.C. 1 1 2: 
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The specification sliall contain a written description of the invention, and of the manner and process of 
mailing and using it, in such full, clear, concise, and exact terms as to enable any person skilled in the 
art to which it pertains, or with which it is most nearly connected, to make and use the same and shall 
set forth the best mode contemplated by the inventor of carrying out his invention. 

9. Claims 1-45 are rejected under 35 U.S.C. 112, first paragraph, as failing to 
comply with the written description requirement. The claim(s) contains subject matter 
which was not described in the specification in such a way as to reasonably convey to 
one skilled in the relevant art that the inventor(s), at the time the application was filed, 
had possession of the claimed invention, "...without loading the third set of instructions 
into the execution unit and without loading the second set of instructions into the 
execution unit when loading the first set of instruction" recited in claim 1 or similar 
concept recited in other independent claims are not originally disclosed in the 
specification. All the dependent claims are suffered the same deficiency. 



Claim Rejections - 35 USC §112 

1 0. The following is a quotation of the second paragraph of 35 U.S.C. 1 1 2: 

The specification shall conclude with one or more claims particularly pointing out and distinctly 
claiming the subject matter which the applicant regards as his invention. 

1 1 . Claims 1-45 are rejected under 35 U.S.C. 112, second paragraph, as being 
indefinite for failing to particularly point out and distinctly claim the subject matter which 
applicant regards as the invention. 

Regarding claims 1, 7, 12, 17, 21, 26, 30, 36, and 41 recite "...without loading the 
third set of instructions into the execution unit and without loading the second set of 
instructions into the execution unit when loading the first set of instruction" is unclear 
and contradicting with other claimed limitations of the claims. Instructions must be 
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loaded into the execution unit in order to be executed. For examining purposes, the 
examiner interprets that the second and third sets of instructions are loaded In order to 
be executed. Similar concept Is also found In other Independent claims. All the 
dependent claims are suffered the same deficiency. 

Claim Rejections - 35 USC § 102 

1 2. The following is a quotation of the appropriate paragraphs of 35 U.S.C. 1 02 that 
form the basis for the rejections under this section made in this Office action: 

A person shall be entitled to a patent unless - 

(b) the Invention was patented or described in a printed publication in this or a foreign country or in public 
use or on sale in this country, more than one year prior to the date of application for patent in the United 
States. 

1 3. Claims 1 , 2, 4-8, 17,21, 22, 24-26, 30, 31 , 33-37 and 39 are rejected under 35 
U.S.C. 102(b) as being anticipated by Szoke (United States Patent No.: 4,787,034). 

As per claims 1 and 30 : 
Szoke discloses: 

- loading a first set of instructions into an execution unit (see at least FIG. 1, 
"program P11"), wherein the first set of instructions includes an unresolved 
reference to a second set of Instructions ("CALL P21" or "CALL P24"), 
wherein the loading includes replacing the unresolved reference with an 
address of a third set of instructions ("when the statement CALL 'P21' in 
program P11 is executed, control is passed to the statement at entry 
point P21 in E-Table 120, i.e., to branch statement 122. Branch 
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statement 122 causes a branch to linkage program 130" col. 4, line 3-7, 
also see at least FIG. 1); 

- executing instructions of the first set ("when the statement CALL 'P21' in 
program P11 is executed " col. 4, line 3-4); 

- executing instructions of the third set ("Branch statement 122 causes a 
branch to linkage program 130" col. 4, line 6-7), wherein executing 
instructions of the third set includes loading the second set of instructions into 
the execution unit ("when load module 200 is loaded by linkage program 
130 of module 100" col. 4, line 25-26); and 

- executing instructions of the second set ("linkage program 130 transfers 
control to the actual address of program P21 in load module 200. 
Program P21 CALLs programs P22 and P23, and then returns to 
program P11" col. 4, line 45-48). 

As per claims 2. 22 and 31 : 
Szoke discloses: 

- wherein the first set of instructions includes an executable object module 
("load module 100 (LM-1)" col. 2, line 53-54, also see at least FIG. 1). 



As per claims 4. 24 and 34 : 



Szoke discloses: 
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- wherein the second set of instructions includes a separately compiled object 
module ("load module 200 (LM-2) " col. 2, line 54, also see at least FIG. 1). 

As per claims 5. 25 and 35 : 
Szoke discloses: 

- wherein the third set of instructions includes a loader unit ("linkage program 
130 " col. 4, line 7, also see at least FIG. 1). 

As per claims 6 and 33 : 
Szoke discloses: 

- wherein the loading does not include determining whether the unresolved 
reference refers to a defined external symbol ("linkage program 130 
determines tlie address of T-table 260 from the load address of load 
module 200 supplied by the operating system " col. 4, line 17-19, 
therefore, Szoke does not determining whether the unresolved 
reference refers to a defined external symbol). 

As per claims 7 and 36 : 
Szoke discloses: 

- compiling a source code module into an executable object module that 
includes an unresolved reference to a separately compiled object module 
("the compiler has no way to determine the address of the callable 
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program, the compiler lists the callable program as an unresolved 
external reference" col. 1, line 38-40); 

- loading the executable object module (see at least FIG. 1, "program P11"), 
wherein the loading includes replacing the unresolved reference with a 
reference to a system module ("when the statement CALL 'P21' in 
program P11 is executed, control is passed to the statement at entry 
point P21 in E-Table 120, i.e., to branch statement 122. Branch 
statement 122 causes a branch to linkage program 130" col. 4, line 3-7, 
also see at least FIG. 1), and wherein neither the compiling nor the loading 
include determining whether the unresolved reference refers to a defined 
external symbol ("linkage program 130 determines the address of T-table 
260 from the load address of load module 200 supplied by the operating 
system " col. 4, line 17-19, therefore, Szoke does not determining whether 
the unresolved reference refers to a defined external symbol); 

- executing the executable object module, wherein the executing includes, 
calling the system module for loading the separately compiled object module 
("when load module ICQ is created (executed). Therefore, when the 
statement CALL 'P21' in program P11 is executed" col. 4, line 2-4); and 

- executing the separately compiled object module ("linkage program 130 
transfers control to the actual address of program P21 in load module 
200. Program P21 CALLs programs P22 and P23, and then returns to 
program P11"" col. 4, line 45-48). 
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As per claims 8 and 39 : 
Szol^e discloses: 

- wherein the system module includes a loader unit ("linkage program 130" 
col. 4, line 7). 

As per claim 17 : 

Szoke discloses an apparatus comprising: 

- a compiler unit to create an executable object module based on a source 
code module ("compiler" col. 1, line 38), wherein the executable object 
module includes an unresolved reference to a separately compiled object 
module ("the compiler lists the callable program as an unresolved 
external reference" col. 1, line 39-41); 

- a storage unit to store the executable object module ("storage space" col. 1 , 
line 65); 

- an execution unit to receive the executable object module ("linkage editor" 

col. 3, line 9); and 

- a loader unit to find the executable object module in the storage unit and 
present the executable object module to the execution unit ("linkage 
program 130 causes the operating system to load the load module 
identified by literal constant 123, i.e., load module 200" col. 4, line 7-10), 
wherein the loader unit is to replace the unresolved reference with a 
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reference to a system module ("when load module 200 has been loaded, 
the operating system will return the load address of load module 200 to 
linkage program 130" col. 4, line 10-12), and wherein the loader unit is not to 
determine whether the unresolved reference refers to a defined external 
object module ("linkage program 130 determines the address of T-table 
260 from the load address of load module 200 supplied by the operating 
system" col. 4, line 17-19, therefore, Szoke does not determining whether 
the unresolved reference refers to a defined external symbol). 

As per claim 21 : 

Szoke discloses: 

- a loader unit to load a first set of instructions into a memory unit ("load 
module 100 (LM-1)", col. 2, line 53-54, this means, the module is already 
loaded in memory), wherein the first set of instructions includes an 
unresolved reference to a second set of instructions ("when load module 
100 is created the statements CALL 'P21' in program P11 and CALL 
'P24' in program P12 would not ordinarily be resolved, and would 
instead be listed as unresolved external references" col. 3, line 5-10), the 
loader unit to replace the unresolved reference with an address of a third set 
of instructions ("when load module 200 has been loaded, the operating 
system will return the load address of load module 200 to linkage 
program 130" col. 4, line 10-12); and 
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- an execution unit to execute instructions of the first set ("when load module 
100 is created (executed)" col. 4, line 2), the execution unit also to execute 
instructions of the third set to determine an address of the second set of 
instructions ("Branch statement 122 causes a branch to linkage program 
130" col. 4, line 6-7), wherein the loader unit is to use the address of the 
second set of instructions to load the second set of instructions into the 
memory unit ("when load module 200 is loaded by linkage program 130 of 
load module 100, these relative addresses are converted to the actual 
loaded addresses of program P21 and P24 respectively" col. 4, line 25- 
28). 



As per claim 26 : 

Szoke discloses a system comprising: 

- a memory unit, the memory unit including, a compiler unit to create an 
executable object module based on a source code module, wherein the 
executable object module includes a symbolic reference to a separately 
compiled object module ("when load module 100 is created the statements 
CALL 'P21' in program P11 and CALL 'P24' in program P12 would not 
ordinarily be resolved, and would instead be listed as unresolved 
external references" col. 3, line 5-10); 

- a loader unit to present the executable object module for execution, wherein 
the loader unit is to replace the symbolic reference with an address to a 



Application/Control Number: 10/797,515 Page 14 

Art Unit: 2191 

system module ("when load module 200 has been loaded, the operating 
system will return the load address of load module 200 to linkage 
program 130" col. 4, line 10-12), and wherein the loader unit is not to 
determine whether the symbolic reference refers to a defined external object 
module ("linkage program 130 determines the address of T-table 260 
from the load address of load module 200 supplied by the operating 
system" col. 4, line 17-19, therefore, Szoke does not determining whether 
the unresolved reference refers to a defined external symbol); and 
- a processor to receive the executable object module from the loader unit of 
the memory unit (it is inherent in order to process the load modules). 



As per claim 37 : 

Szoke discloses: 

- wherein the determining the address includes looking-up the address in a 
master symbol table ("linkage program 130 determines the address of T- 
table 260 from the load address of load module 200 supplied by the 
operating system" col. 4, line 17-19). 



Claim Rejections - 35 USC § 103 
14. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 



(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
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invention was made to a person liaving ordinary skill in tlie art to wliicli said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

15. Claims 9, 14, and 43 are rejected under 35 U.S.C. 103(a) as being unpatentable 
over Szoke (United States Patent No.: 4,787,034). 

As per claims 9. 14. 43 : 

Szoke does not explicitly discloses: 

- wherein the loader unit is a dyld loader. 

However, it would have been obvious to one having an ordinary skill in the art at 
the time the invention was made to recognize that linkage program 130 is performed 
dynamically ( "the CALLs to programs P21 and P24 to be resolved dynamically at 
the time that load module 100 is executed" col. 3, line 11-13). 

Therefore, one of ordinary skill in the art would have been motivated to use dyld 
loader because it is also dynamic loader and available from Apple Computer, Inc. 

16. Claims 3, 11, 13, 19, 23, 28, 32, 40 and 42 are rejected under 35 U.S.C. 103(a) 
as being unpatentable over Szoke (United States Patent No.: 4,787,034), in view of 
"Apple Developer Connection" Apple Computer Inc. 2001 . 



As per claims 3.11.13,19, 23, 28. 32. 40 and 42 : 
Szoke does not explicitly disclose: 

- wherein the executable object module is in the Mach-0 object format. 
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However, Apple Developer Connection 2001 discloses the use of Mach-0 file 
format. It would have been obvious to one having an ordinary skill in the art at the time 
the invention was made to recognize that Mach-0 is a well know file format in the art for 
executable object code and use it in Szoke's approach for storing executable object 
code. 

Therefore, one would have been motivated to use Mach-0 file format because it 
provides both intermediate and final storage of machine code and data. It was 
designed as a flexible replacement for the BSD a.out format to be used by the compiler. 

Claim 10, 18, 20, 27, and 29 are rejected under 35 U.S.C. 103(a) as being unpatentable 
over Szoke (United States Patent No.: 4,787,034), in view of Tatge et al. (United States 
Patent No.: 5,293,630). 

As per claims 10. 18. 20. 27. 29. 38: 

Szoke does not explicitly disclose: 

- wherein the source code module includes instructions of a dialect of the C 
programming language. 

However, Tatge discloses an analogous method of returning a data structure 
from a callee function to a caller function fro the C programming language (col. 2, line 
65). It would have been obvious to one having an ordinary skill in the art at the time the 
invention was made to recognize that in Szoke's approach, a compiler lists the external 
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call as unresolved external references (see at least col. 1, line 39-40). Every high-level 
programming language comes with a compiler. 

Therefore, one of ordinary sl<ill in the art would have been motivated to apply 
Szoke's approach to C programming language as disclose in Tatge's approach because 
C is one of the high level programming languages. 

17. Claims 12, 15, 16, 41, 44, and 45 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Szoke (United States Patent No.: 4,787,034), in view of Sexton et al. 
(United States Patent No.: US 6,434,685). 

As per claims 1 2 and 41 : 
Szoke discloses: 

- creating an executable object module that includes symbolic references to 
addresses in ones of a set of one or more separately compiled object 
modules (see at least FIG. 1, "load module 100 (LM-1) " and "program 
P11"); 

- replacing the symbolic references with addresses to a loader subroutine (see 
at least FIG. 1, "CALL 'P21' or CALL 'P24' "); 

- executing the executable object module ('"when load module 100 is created 
(executed)" col. 4, line 2), wherein executing includes, executing the loader 
subroutine to load one of the separately compiled object modules (""when the 
statement CALL 'P21' in program P11 is thereafter executed, control is 
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passed to the statement at entry point P21 in E-table 120 " col. 4, line 3-5); 

and 

- executing the one of tine separately compiled object modules ("linkage 
program 130 transfers control to the actual address of program P21 in 
load module 200. Program P21 CALLs programs P22 and P23, and then 
returns to program P11" col. 4, line 45-48). 

Szoke does not explicitly disclose: 

- wherein the executable object module includes a page-aligned code segment 
and a page-aligned data segment, and wherein the object module includes 
resolved internal code-to-data offsets. 

However, Sexton discloses a method for paged memory management system 
within a runtime environment that solves the page-aligned problem (Abstract). It would 
have been obvious to one having an ordinary skill in the art at the time the invention 
was made to combine Sexton's approach with Szoke to improve the performance. The 
combination is obvious because one of ordinary skill would have been motivated to 
save memory and improve the performance of page associated memory management 
operation by perform page-aligned code segment and a page-aligned data segment 
(Sexton at least col. 12:1-8). 



As per claims 15 and 44 : 



Szoke discloses: 
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- wherein the unresolved reference is a reference is a function call to a function 
included in one of the separately compiled object modules of the set 
("Program P11 includes statements that CALL programs P21" col. 2, line 
63-64). 

As per claims 16 and 45 : 

Szoke does not explicitly disclose: 

- wherein the unresolved reference is a reference to a variable defined within 
one of the separately compiled objects of the set. 

However, it would have been obvious to one having an ordinary skill in the art at the 
time the invention was made to recognize that calls to program P21 or P24 is also 
including calls to variables within program P21 or P24 of module 200. One of ordinary 
skill in the art would have been motivated to call to variables within P21 or P24 of 
module 200 because calling external variables are also considered as external 
unresolved references that need to be resolved dynamically at the time the module 100 
is executed. 

Conclusion 

18. The prior art made of record and not relied upon is considered pertinent to 
applicant's disclosure. 

19. Mulchandani et al. teaches a system and method for dynamic program linking. 
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20. THIS ACTION IS MADE FINAL. Applicant is reminded of the extension of time 
policy as set forth in 37 CFR 1 .136(a). 

21 . A shortened statutory period for reply to this final action is set to expire THREE 
MONTHS from the mailing date of this action. In the event a first reply is filed within 
TWO MONTHS of the mailing date of this final action and the advisory action is not 
mailed until after the end of the THREE-MONTH shortened statutory period, then the 
shortened statutory period will expire on the date the advisory action is mailed, and any 
extension fee pursuant to 37 CFR 1 .136(a) will be calculated from the mailing date of 
the advisory action. In no event, however, will the statutory period for reply expire later 
than SIX MONTHS from the mailing date of this final action. 

22. Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Phillip H. Nguyen whose telephone number is (571) 
270-1070. The examiner can normally be reached on Monday - Thursday 10:00 AM - 
3:00 PM EST. 

23. If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Wei Y. Zhen can be reached on (571) 272-3708. The fax phone number for 
the organization where this application or proceeding is assigned is 571-273-8300. 



Application/Control Number: 10/797,515 Page 21 

Art Unit: 2191 

24. Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). If you would like assistance from a 
USPTO Customer Service Representative or access to the automated information 
system, call 800-786-9199 (IN USA OR CANADA) or 571-272-1000. 



PN 

10/26/2009. 
/Wei Y Zhen/ 

Supervisory Patent Examiner, Art Unit 2191 



